package com.zdcp.system.mapper;

import java.util.List;

import org.beetl.sql.core.annotatoin.Param;
import org.beetl.sql.core.annotatoin.SqlResource;
import org.beetl.sql.core.mapper.BaseMapper;

import com.zdcp.system.bean.SysDept;

/**
 * 部门管理
 * 
 * @author yweijianz
 * @date 2019年8月16日
 * @version 1.0
 */
@SqlResource("system.sysDept")
public interface SysDeptMapperDao extends BaseMapper<SysDept> {
	/**
	 * 查询部门人数
	 * 
	 * @param dept
	 *            部门信息
	 * @return 结果
	 */
	public int selectDeptCount(SysDept dept);

	/**
	 * 查询部门是否存在用户
	 * 
	 * @param deptId
	 *            部门ID
	 * @return 结果
	 */
	public int checkDeptExistUser(Long deptId);

	/**
	 * 查询部门管理数据
	 * 
	 * @param dept
	 *            部门信息
	 * @return 部门信息集合
	 */
	public List<SysDept> selectDeptList(SysDept dept);

	/**
	 * 删除部门管理信息
	 * 
	 * @param deptId
	 *            部门ID
	 * @return 结果
	 */
	public int deleteDeptById(Long deptId);

	/**
	 * 修改子元素关系
	 * 
	 * @param depts
	 *            子元素
	 * @return 结果
	 */
	public int updateDeptChildren(@Param("depts") List<SysDept> depts);

	/**
	 * 根据部门ID查询信息
	 * 
	 * @param deptId
	 *            部门ID
	 * @return 部门信息
	 */
	public SysDept selectDeptById(Long deptId);

	/**
	 * 校验部门名称是否唯一
	 * 
	 * @param deptName
	 *            部门名称
	 * @param parentId
	 *            父部门ID
	 * @return 结果
	 */
	public SysDept checkDeptNameUnique(@Param("deptName") String deptName, @Param("parentId") Long parentId);

	/**
	 * 根据角色ID查询部门
	 *
	 * @param roleId
	 *            角色ID
	 * @return 部门列表
	 */
	public List<String> selectRoleDeptTree(Long roleId);

	/**
	 * 修改所在部门的父级部门状态
	 * 
	 * @param dept
	 *            部门
	 */
	public void updateDeptStatus(SysDept dept);

	/**
	 * 根据ID查询所有子部门
	 * 
	 * @param deptId
	 *            部门ID
	 * @return 部门列表
	 */
	public List<SysDept> selectChildrenDeptById(Long deptId);
}
